<template>
  <div id="cnblogs_post_body">
    <h2>这是一个可支持对前端、后台基础业务代码扩展的快速发开框架，现框架可直上手开发这些功能</h2>
    <blockquote>
      <ul>
        <li>Vol.WebApi类库可独立用于restful api服务单独部署,用于其他系统单独提供接口,直接上手编写业务代码即可。</li>
        <li>Vue+Vol.WebApi 可用于现有框架前后端分离进行开发</li>
        <li>Vol.Web类库可用于传统MVC+Razor方式进行项目开发</li>
        <li>Vol.Builder类库可作为一个独立的代码生成器,可生成cshtml页面、Vue页面、Model文件、Service与Repository.cs业务处理代码类</li>
        <li>可作为一个独立站点来发布Editor编辑器生成的静态html网页.</li>
        <li>
          可直接用于H5移动App开发
          <a
            title="H5开发看这里"
            href="http://132.232.2.109/app/guide"
            target="_blank"
          >H5开发看这里</a>
        </li>
      </ul>
    </blockquote>
    <h2>框架特点</h2>
    <blockquote>
      <ul>
        <li>支持前端、后台基础业务代码动态扩展，可在现有框架增、删、改、查、导入、导出、审核基础业务上扩展复杂的业务代码</li>
        <li>基本业务全部由框架完成，上手即可对基础业务以外的代码进行扩展</li>
        <li>上手简单，需要.net core2.1、VsCode mysql/sqlservcer 2012、redis(可选) 及以上版本的开发环境</li>
        <li>学习成本低，封装了常用可扩展组件及Demo(前端基于Iview/Element-UI组件进行了二次封装、后台提供了大量的扩展方法)</li>
        <li>开发效率高,内定制开发的代码生成器,生成前端(Vue、后台代码),代码生成器已完成90%以上的重复工作，只需要在提供的扩展类型中实现其他业务</li>
        <li>前端vue页面表单下拉/多选框完成自动绑定数据源，不需要写任何代码,并支持扩展自定开发绑定。</li>
        <li>后台已完成权限、菜单、JWT等内部功能</li>
      </ul>
    </blockquote>
    <p
      class="desc"
      style="color:white; background: #009688;"
    >如果你没有做过webpack+vue工程化开发项目，可能会刚开始相当不适应，或者安装环境总是出问题，但只要你熟悉开发流程后，你会发现采用Vue开发比Jquery爽太多了。上手项目需重点了解基础Vue语法，特别是了解组件、路由及import的使用</p>
    <h2>开发及依赖环境</h2>
    <p class="desc">
      S2017 、.NetCore2.1 、EFCore2.1、JWT、Dapper、Autofac、SqlServer/MySql、Redis(可选，没有redis的在appsetting.json中不用配置，默认使用内置IMemory)、
      <br />VsCode、Vue2.0（webpack、node.js,如果没有此环境自行搜索:vue webpack npm)、Vuex、axios、promise、IView、Element-ui
    </p>
    <h2>项目运行</h2>
    <p class="desc">
      如果你没有前端环境，请先安装node
      <br />前端开发使用VsCode
    </p>
    <blockquote>
      <ul>
        <li>1、使用cmd命令切换至前端Vue项目.../VOL.Vue路径下,执行npm install命令(只有从来没执行过此命令的才执行npm install)</li>
        <li>
          2、运行后端项目：在后端项目路径.../VOL.WebApi/运行builder_run.bat
          <span>端口设置的是9991</span>,运行前先看appsettings.josn配置属性说明
        </li>
        <li>3、运行前端项目：在前端Vue项目路径.../VOL.Vue/运行run.bat（每次启动会进行编译，这个时间可能会有点长）</li>
        <li>4、输入http://localhost:8080访问</li>
      </ul>
    </blockquote>
    <h2>功能介绍</h2>
    <table>
      <tr>
        <td style=" min-width: 140px;">功能</td>
        <td>描述</td>
        <td>完成情况</td>
      </tr>
      <tr>
        <td>用户管理(登陆、密码修改)</td>
        <td>登陆、密码修改</td>
        <td>√</td>
      </tr>
      <tr>
        <td>角色管理</td>
        <td>角色管理</td>
        <td>√</td>
      </tr>
      <tr>
        <td>权限分配</td>
        <td>用户基础权限分配，后台支持多种权限控制方式,也可自行定义</td>
        <td>√</td>
      </tr>
      <tr>
        <td>用户权限/菜单静态化处理</td>
        <td>为减少Redis读取数据传输量,对用户权限/菜单在本地服务器作静态化处理,只有在用户权限/菜单变化时才刷新redis缓存</td>
        <td>√</td>
      </tr>
      <tr>
        <td>JWT认证</td>
        <td>采用前台端分离JWT认证，并且支持JWT过期动态刷新</td>
        <td>√</td>
      </tr>
	 <tr>
            <td>
                异步队列批量写日志
            </td>
            <td>
                框架封装了一个异步队列写日志,此前项目每天PV约150W左右，采用异步队列的方式批量写入日志非常顺畅
            </td>
            <td>
                √
            </td>
        </tr>
      <tr>
        <td>Repository</td>
        <td>Repository作为数据提供，提供了常用EF方法封装</td>
        <td>√</td>
      </tr>
      <tr>
        <td>前端常用组件封装</td>
        <td>此框架主要围绕表单组件进行开发，并且封装的组件都支持扩展</td>
        <td>√</td>
      </tr>
      <tr>
        <td>基础业务实现</td>
        <td>已实现(表/主从表)的增、删、改、查、导入、导出、审核基础功能(前提建一张带主键的mysql/sqlserver表),这些基础业务不要写任何代码，直接用代码生成器生成即可，并且生成的代码支持其他业务代码扩展</td>
        <td>√</td>
      </tr>
      <tr>
        <td>代码生成器</td>
        <td>代码生成器为可视化配置，提供了可配置属性的20多种，所有基础功能只需要勾选确认，生成的代码包括Vue/Vue扩展文件/路由,后台表相关的类(控制器/扩展控制器,业务接口/扩展业务接口,接口实现/扩展接口实现类)，支持单表表单、主从表单的代码生成</td>
        <td>√</td>
      </tr>
      <tr>
        <td>数据源预先配置</td>
        <td>数据源作为前端下拉框/多选框的字典项源，支持key/value配置及sql从数据源加载配置</td>
        <td>√</td>
      </tr>
      <tr>
        <td>表单数据源自动绑定</td>
        <td>如果一个表单带有多个下拉框，这里只需要配置数据源编号即可自动绑定</td>
        <td>√</td>
      </tr>
      <tr>
        <td>Redis/Memory缓存</td>
        <td>已对Redis/Memory封装直接使用即可</td>
        <td>√</td>
      </tr>
      <tr>
        <td>Dapper</td>
        <td>已对Dapper封装直接使用即可</td>
        <td>√</td>
      </tr>
      <tr>
        <td>扩展方法</td>
        <td>框架封装了大量的扩展方法,如：通用实体校验(框架所有实现校验全部依赖于此扩展)扩展、string扩展、object扩展、表达式生成/解析扩展、文件操作扩展等</td>
        <td>√</td>
      </tr>
      <tr>
        <td>H5开发</td>
        <td>
          可支持直接开发并部署H5页面
          <a
            title="H5开发看这里"
            href="http://132.232.2.109/app/guide"
            target="_blank"
          >H5开发看这里</a>
        </td>
        <td>√</td>
      </tr>
      <tr>
        <td>分库分表</td>
        <td>分库分表操作</td>
        <td>x</td>
      </tr>
      <tr>
        <td>静态页面发布</td>
        <td></td>
        <td>x</td>
      </tr>
      <tr>
        <td>消息推送</td>
        <td></td>
        <td>x</td>
      </tr>
    </table>
    <div
      style=" line-height: 40px; background: #e71616; margin-top: 20px; padding: 0px 30px; border-radius: 4px; color: white;"
    >
      <a style=" color: white;" href="http://132.232.2.109" target="_blank">框架文档、代码生成器、Demo看这里</a>
    </div>
    <div>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/home.png" />
    </div>
    <h2>1、只读基础表单</h2>
    <div>
      <p class="desc">整个只读的基础表单的所有前后端代码，全部由代码生成器生成，代码生成器中几乎不需要配置，并支持并后端业务代码扩展，直接生成代码后，配置菜单权限即可</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/table1.png" />
    </div>
    <h2>2、自动绑定下拉框数据表单</h2>
    <div>
      <p
        class="desc"
      >整个自动绑定下拉框数据表单的所有前后端代码，全部由代码生成器生成，并支持并后端业务代码扩展，在代码生成器中只需要指定数据源编号，页面加载时会根据编号自动加载数据源并绑定</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/table2.png" />
    </div>
    <h2>3、启用图片支持、审核表单</h2>
    <div>
      <p class="desc">整个启用图片支持、审核表单的所有前后端代码，全部由代码生成器生成，并支持并后端业务代码扩展，审核功能需要在菜单配置权限、代码生成器中勾选启用图片支持</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/table3.png" />
    </div>
    <h2>4、高级查询</h2>
    <div>
      <p
        class="desc"
      >整个表单的所有前后端代码，全部由代码生成器生成，并支持并后端业务代码扩展，查询字段、类型(下拉框、日期、TextArea等)、所在行与列都由代码生成器完成，不需要写任何代码</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/tablesearch4.png" />
    </div>
    <h2>5、单表新建、编辑</h2>
    <div>
      <p
        class="desc"
      >单表新建、编辑所有前后端代码，全部由代码生成器生成，并支持并后端业务代码扩展，新建、编辑字段、类型(下拉框、日期、TextArea等)、所在行与列、字段是否只读、标签显示的长度等都由代码生成器完成，不需要写任何代码</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/editTbale1.png" />
    </div>
    <h2>6、主从表新建、编辑</h2>
    <div>
      <p
        class="desc"
      >主从表新建、编辑所有前后端代码，全部由代码生成器生成，并支持并后端业务代码扩展，新建、编辑从表配置、字段、类型(下拉框、日期、TextArea等)、所在行与列、字段是否只读、标签显示的长度等都由代码生成器完成，不需要写任何代码</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/editTbale2.png" />
    </div>
    <h2>7、单列、多列Form表单</h2>
    <div>
      <p
        class="desc"
      >单列、多列Form表单，已封装成组件，并且支持组件扩展。可配置显示的列的数量、是否只读、列的数据类型(日期、下拉框、TextArea、列宽、自动绑定数据源、图片上传等)， 这些只需要配置JSON格式即可使用</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/form2.png" />
    </div>
    <h2>8、可配置的Table(自动/手动加载table数据、自动绑定数据源、编辑功能)</h2>
    <div>
      <p
        class="desc"
      >单列、多列Form表单，已封装成组件，并且支持组件扩展。可配置显示的列的数量、是否只读、列的数据类型(日期、下拉框、TextArea、列宽、自动绑定数据源、图片上传等)， 这些只需要配置JSON格式即可使用</p>
      <p class="desc">从后台加载数据、自动绑定数据</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/loadtable.png" />
      <p class="desc">可编辑的table，手动绑定数据、自动绑定数据源</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/form3.png" />
    </div>
    <p class="desc">表单与table混合使用</p>
    <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/table+form.png" />
    <h2>9、excel导入</h2>
    <div>
      <p
        class="desc"
      >excel导入整个页面都由代码生成器生成，导入的字段、字段是否必填，下载模板也由代码生成器上配置(自己根据实际需要决定是否采用此方法)，导入时会验证是否为空与数据的合法性，逻辑校验自己实现扩展方法即可</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/importTable1.png" />
    </div>
    <h2>10、前端、后台业务代码扩展</h2>
    <div>
      <p class="desc">
        只需要根据自己的业务实现前端、后台代码扩展方法即可。后台大部分都采用的委托扩展方法，这里只截了一张图数据加载事件的扩展方法，完整方法从Demo：
        <a href="http://132.232.2.109/SellOrder">http://132.232.2.109/SellOrder</a>上获取
      </p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/extend.png" />
    </div>
    <h2>11、H5开发</h2>
    <div>
      <p class="desc">
        H5只是做了一个简单的Demo,如果你有H5开发经验，请忽略，如果你没有H5开发经验，
        <a
          title="H5开发看这里"
          href="http://132.232.2.109/app/guide"
          target="_blank"
        >可看看这里</a>
      </p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/h5.jpg" />
    </div>
    <h2>12、权限分配</h2>
    <div>
      <p class="desc">目前只实现了对用户的角色的Action进行权限分配</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/auth.png" />
    </div>
    <h2>13、菜单管理</h2>
    <div>
      <p class="desc">默认8种权限，可自行定义其他权限(代码生成器完后，直接在菜单上配置url(url路径为自动生成前端的router-&gt;path,从此处复制过过即可))</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/menu.png" />
    </div>
    <h2>14、个人中心</h2>
    <div>
      <p class="desc">个人中心目前只开发了页面与修改密码，其他功能自行根据需要实现</p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/user.png" />
    </div>
    <h2>15、代码生成器</h2>
    <div>
      <p class="desc">
        代码生成器提供了20多种可配置的属性，可灵活配置显示、查询、编辑、导入、导出、主从关系等功能
        <a
          href="http://132.232.2.109/document/coder"
        >点击看代码生成器文档</a>
      </p>
      <img src="https://imgs-1256993465.cos.ap-chengdu.myqcloud.com/github/coder.png" />
    </div>
    <br />
    <p class="desc">
      还有角色管理、日志管理、数据源管理、其他组件、后台代码等功能就不再介绍了,
      <a href="http://132.232.2.109">点这里看看就知道了</a>
    </p>
    <br />
    <div class="desc desc-to">
      <div>此框架由代码生成器完成了大部分工作能极大减少代码量,并支持前台端代码的扩展。如果你对前后端分离开发的方式或H5开发有兴趣,那么希望此框架对能你有所帮助！</div>
      <div>如果你觉得框架对你有用，帮忙点个星，非常感谢!</div>
      <div>
        Demo地址：
        <a href="http://132.232.2.109">http://132.232.2.109</a> 帐号：admin666密码：123456（本地超级管理员帐号：admin密码123456）
      </div>
      <div>
        GitHub地址：
        <a
          href="https://github.com/cq-panda/Vue.NetCore.git"
        >https://github.com/cq-panda/Vue.NetCore.git</a>
      </div>
      <div>
        如果你需要Quartz.Net做定时任务管理，你可以试试这个：
        <a
          href="https://github.com/cq-panda/Vue.NetCore.git"
        >https://github.com/cq-panda/Quartz.NetUI</a>
      </div>
      <div>(站点与MySql部署在同一个1G1核1M带宽的服务Centos服务上,访问可能会出现延迟现象)</div>
      <br />
    </div>
  </div>
</template>
<script>
export default {};
</script>
<style>
#cnblogs_post_body {
  color: black;
  font: 0.875em/1.5em "微软雅黑", "PTSans", "Arial", sans-serif;
  font-size: 15px;
}
#各个等级标题的颜色样式 #cnblogs_post_body h1 {
  background: #2b6695;
  border-radius: 6px 6px 6px 6px;
  box-shadow: 0 0 0 1px #5f5a4b, 1px 1px 6px 1px rgba(10, 10, 0, 0.5);
  color: #ffffff;
  font-family: "微软雅黑", "宋体", "黑体", Arial;
  font-size: 23px;
  font-weight: bold;
  height: 25px;
  line-height: 25px;
  margin: 18px 0 !important;
  padding: 8px 0 5px 5px;
  text-shadow: 2px 2px 3px #222222;
}
#cnblogs_post_body h2 {
  background: #00bcd4;
  border-radius: 6px 6px 6px 6px;
  box-shadow: 0 0 0 1px #a3a3a3, 1px 1px 6px 1px rgba(10, 10, 0, 0.5);
  color: #ffffff;
  font-family: "微软雅黑", "宋体", "黑体", Arial;
  font-size: 20px;
  font-weight: bold;
  /* height: 25px; */
  line-height: 37px;
  margin: 18px 0 !important;
  /* padding: 8px 0 5px 5px; */
  padding: 2px 20px;
  text-shadow: 2px 2px 3px #635555;
}

#cnblogs_post_body h3 {
  background: #399ab2;
  border-radius: 6px 6px 6px 6px;
  box-shadow: 0 0 0 1px #5f5a4b, 1px 1px 6px 1px rgba(10, 10, 0, 0.5);
  color: #ffffff;
  font-family: "微软雅黑", "宋体", "黑体", Arial;
  font-size: 18px;
  font-weight: bold;
  height: 25px;
  line-height: 25px;
  margin: 18px 0 !important;
  padding: 8px 0 5px 5px;
  text-shadow: 2px 2px 3px #222222;
}
#cnblogs_post_body h4 {
  background: #2b6600;
  border-radius: 6px 6px 6px 6px;
  box-shadow: 0 0 0 1px #5f5a4b, 1px 1px 6px 1px rgba(10, 10, 0, 0.5);
  color: #ffffff;
  font-family: "微软雅黑", "宋体", "黑体", Arial;
  font-size: 16px;
  font-weight: bold;
  height: 24px;
  line-height: 23px;
  margin: 12px 0 !important;
  padding: 5px 0 5px 10px;
  text-shadow: 2px 2px 3px #222222;
}

#cnblogs_post_body table {
  border-collapse: collapse;
}
#cnblogs_post_body table td {
  color: rgba(111, 93, 93, 0.87);
  font-size: 13px;
  border-collapse: collapse;
  padding: 7px;
  min-width: 60px;
  border: 1px solid #607d8b;
  text-align: left;
}
#cnblogs_post_body img {
  width: 100%;
  margin-bottom: 30px;
  margin-top: 10px;
}
#页面中a标签鼠标位置 #cnblogs_post_body h2:a {
  color: rgb(235, 235, 235);
}
#cnblogs_post_body h2 a:hover {
  color: rgb(255, 102, 0);
}
#页面中标题位置 #cnblogs_post_body h1 {
  color: rgb(235, 235, 235);
}
#cnblogs_post_body h1:hover {
  color: rgb(255, 102, 0);
}
#cnblogs_post_body h2 {
  color: rgb(235, 235, 235);
}
#cnblogs_post_body h2:hover {
  color: rgb(255, 102, 0);
}
#cnblogs_post_body h3 {
  color: rgb(235, 235, 235);
}
#cnblogs_post_body h3:hover {
  color: rgb(255, 102, 0);
}
#cnblogs_post_body h4 {
  color: rgb(235, 235, 235);
}
#cnblogs_post_body h4:hover {
  color: rgb(255, 102, 0);
}
#cnblogs_post_body blockquote {
  margin: 20px 0;
  padding: 15px 20px 15px 60px;
  font-size: 15px;
  background: #f7ed91;
  font-family: "Microsoft Yahei";
  box-shadow: 0 0 8px #aaa;
  clear: both;
  line-height: 1.6em;
  color: #333;
}
#cnblogs_post_body blockquote li {
  padding: 15px 2px 5px 5px;
  /* line-height: 1.5; */
  /* color: #000; */
  border-bottom: 1px solid #ccc;
  /* list-style-type: disc; */
  margin-bottom: 0.5em;
}

#cnblogs_post_body .desc {
  background: rgb(230, 250, 250);
  padding: 10px 10px 10px 10px;
  border: 1px dashed rgb(224, 224, 224);
  font-family: 微软雅黑;
  font-size: 13px;
}

#cnblogs_post_body .desc-to {
  background: #4caf50;
  color: white;
}
#cnblogs_post_body .desc-to > div {
  padding: 10px 16px;
}
#cnblogs_post_body .desc-to a {
  color: yellow;
  font-weight: bold;
  margin-right: 25px;
}
</style>
